<template>
  <div>
    <div style="display: flex; justify-content: space-between;">
      <el-button type="primary" icon="el-icon-plus" @click="showAddSalaryView">添加工资账套</el-button>
      <el-button type="primary" icon="el-icon-refresh" @click="initSalaries()"></el-button>
    </div>

    <div style="margin-top: 10px;">
      <el-table
        :data="salaries"
        border
        stripe>
        <el-table-column
          type="selection"
          width="40">
          <el-table-column
            prop="name"
            label="账套名称"
            width="120">
          </el-table-column>
          <el-table-column
            prop="basicSalary"
            label="基本工资"
            width="70">
          </el-table-column>
           <el-table-column
            prop="trafficSalary"
            label="交通补助"
            width="70">
          </el-table-column>
          <el-table-column
            prop="lunchSalary"
            label="午餐补助"
            width="70">
          </el-table-column>
           <el-table-column
            prop="bonus"
            label="奖金"
            width="70">
          </el-table-column>
          <el-table-column
            prop="createData"
            label="启用时间"
            width="100">
          </el-table-column>
          <el-table-column
            align="center"
            label="养老金">
            <el-table-column
              prop="pensionPer"
              label="比率"
              width="70">
            </el-table-column>
            <el-table-column
              prop="pensionBase"
              label="基数"
              width="70">
            </el-table-column>
          </el-table-column>
          <el-table-column
            align="center"
            label="医疗保险">
            <el-table-column
              prop="medicalPer"
              label="比率"
              width="70">
            </el-table-column>
            <el-table-column
              prop="medicalBase"
              label="基数"
              width="70">
            </el-table-column>
          </el-table-column>
          <el-table-column
            align="center"
            label="公积金">
            <el-table-column
              prop="accumulationPer"
              label="比率"
              width="70">
            </el-table-column>
            <el-table-column
              prop="accumulationBase"
              label="基数"
              width="70">
            </el-table-column>
          </el-table-column>
        </el-table-column>
        <el-table-column
          label="操作" >
        </el-table-column>
        <template slot-scope="scope">
          <el-button type="primary" @click="showEditSalaryView(scope.row)">编辑</el-button>
          <el-button type="danger" @click="deleteSalary(scope)">删除</el-button>
        </template>

      </el-table>
    </div>
    <el-dialog
      ：title="dialogTitle"
      :visible.sync="dialogVisible"
      width="50%"
      :before-close="handleClose">
      <div>
        <div style="height: 300px;">
          <el-steps direction="vertical" :active="activeItemIndex">
            <el-step :title="itemName" v-for="(itemName ,index) in salaryItemName" :key="index"></el-step>
          </el-steps>
          <el-input v-model="i" 
          :placeholder="'请输入' + itemName + '...'" 
          v-for="(itemName ,index) in salaryItemName" 
          :key="index"
          v-show="activeItemIndex === index"
          style="display: flex;justify-content: space-around;align-items: center;"></el-input>
          <!-- 让序号等于index的时候才展示相应input -->
        </div>
      </div>
      <span slot="footer" class="dialog-footer">
        <el-button @click="preStep" :disabled="activeItemIndex === 0?false:true">{{activeItemIndex === 10?'取消':'上一步'}}</el-button>
        <el-button type="primary" @click="nextStep">{{activeItemIndex === 10?'完成':'下一步'}}</el-button>
      </span>
    </el-dialog>
  </div>
</template>

<script>
export default{
  name: 'SalSob',
  data(){
    return{
      dialogTitle: '添加工资账套',
      salaries:[],
      dialogVisible: false,
      activeItemIndex: 0,
      salaryItemName:[
        '账套名称',
        '基本工资',
        '交通补助',
        '午餐补助',
        '奖金',
        '养老金比率',
        '养老金基数',
        '医疗保险比率',
        '医疗保险基数',
        '公积金比率',
        '公积金基数',
      ],
      salary:{
        name: '',
        basicSalary: 0,
        trafficSalary: 0,
        lunchSalary: 0,
        bounds: 0,
        pensionPer: 0,
        pensionBase: 0,
        medicalPer: 0,
        medicalBase: 0,
        accumulationFundPer: 0,
        accumulationFundBase: 0,
      }
    }
  },
  mounted(){
    this.initSalaries()
  },
  methods: {
    showEditSalaryView(data){
      this.dialogTitle = '编辑工资账套'
      this.activeItemIndex = 0
      this.salary.id = data.id
      this.salary.basicSalary = data.basicSalary
      this.salary.trafficSalary = data.trafficSalary
      this.salary.lunchSalary = data.lunchSalary
      this.salary.bounds = data.bounds
      this.salary.pensionPer = data.pensionPer
      this.salary.pensionBase = data.pensionBase
      this.salary.medicalPer = data.medicalPer
      this.salary.medicalBase = data.medicalBase
      this.salary.accumulationFundPer = data.accumulationFundPer
      this.salary.accumulationFundBase = data.accumulationFundBase//把每行对应的数据放到弹出框的input
      this.dialogVisible = true
    },
    deleteSalary(data){
        this.$confirm('此操作将删除[' + data.nameZh + ']工资账套, 是否继续?', '提示', {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'warning'
      }).then(() => {
        this.deleteRequest('/salary/sob/' + data.id).then(res=>{
          if(res){
            this.initSalaries()//删除完毕后刷新表格
          }
        })
      }).catch(() => {
        this.$message({
          type: 'info',
          message: '已取消删除'
        });
      });
    },
    preStep(){
      if(this.activeItemIndex === 0){
        return
      }
      if(this.activeItemIndex === 10){
        this.dialogVisible = false
        return
      }
      this.activeItemIndex--
    },
    nextStep(){
      if(this.activeItemIndex === 10){
        if(this.salary.id){//这里直接使用了dialog的input，所以进行一个判断
        //如果有salary.id说明是在进行编辑,更新后台的账套
          this.putRequest('/salary/sob/', this.salary).then(res => {
            if(res){
              this.initSalaries()//完事了更新一下前台
              this.dialogVisible = false//关掉弹窗
            }
          })
        }else{//没有就是在这里
          this.postRequest('/salary/sob/', this.salary).then(res => {
          if(res){
            this.initSalaries()
            this.dialogVisible = false
          }
        })
      }
        }
      this.activeItemIndex++
    },
    showAddSalaryView(){
      this.dialogTitle = '添加工资账套'
      this.salary = {
        name: '',
        basicSalary: 0,
        trafficSalary: 0,
        lunchSalary: 0,
        bounds: 0,
        pensionPer: 0,
        pensionBase: 0,
        medicalPer: 0,
        medicalBase: 0,
        accumulationFundPer: 0,
        accumulationFundBase: 0,
      }
      this.activeItemIndex = 0
      this.dialogVisible = true
    },
    initSalaries(){
      this.getRequest('/salary/sob/').then(res => {
        if(res){
          this.salaries = res
        }
      })
    }
  }
}
</script>

<style scoped>

</style>
